<template>
  <div v-loading="loading" class="dashboard-container">
    <div class="app-container">
      <h2>
        <el-card class="tree-card">
          <!-- 用了一个行列布局 -->
          <!-- 缺少tree-node -->
          <tree-tools :tree-node="company" :is-root="true" @addDepts="addDepts" />
          <!--放置一个属性   这里的props和我们之前学习的父传子 的props没关系-->
          <el-tree :data="departs" :props="defaultProps" default-expand-all>
            <!-- 说明el-tree里面的这个内容 就是插槽内容 => 填坑内容  => 有多少个节点循环多少次 -->
            <!-- scope-scope 是 tree组件传给每个节点的插槽的内容的数据 -->
            <!-- 顺序一定是 执行slot-scope的赋值 才去执行 props的传值 -->
            <tree-tools slot-scope="{ data }" :tree-node="data" @delDepts="getDepartments" @addDepts="addDepts" @editDepts="editDepts" />
          </el-tree>
        </el-card>
      </h2>
    </div>
    <!-- 放置新增弹层组件    .sync的修饰符表示会自动的从 update:props事件中自动将你后面传的值设置给变量 -->
    <add-dept ref="addDept" :show-dialog.sync="showDialog" :tree-node="node" @addDepts="getDepartments" />
  </div>
</template>

<script>
import TreeTools from './components/tree-tools'
import { getDepartments } from '@/api/departments'
import { transListToTreeData } from '@/utils'
import AddDept from './components/add-dept' // 引入新增部门组件
export default {
  components: {
    TreeTools,
    AddDept

  },
  data() {
    return {
      loading: false, // 用来控制进度弹层的显示和隐藏
      showDialog: false, // 显示窗体
      node: null,
      defaultProps: {
        label: 'name'
      },
      departs: [],
      company: {

      }
    }
  },
  created() {
    this.getDepartments() // 调用获取组织架构接口
  },
  methods: {

    async getDepartments() {
      this.loading = true
      const result = await getDepartments()
      this.company = { name: result.companyName, manager: '负责人', id: '' } /* 这里定义一个空字符串 因为它是所有子节点的数据pid都是"" */
      this.departs = transListToTreeData(result.depts, '')
      this.loading = false
    },
    addDepts(node) {
      this.showDialog = true // 显示弹层
      // 因为node是当前的点击的部门， 此时这个部门应该记录下来,
      this.node = node
    },
    // 点击编辑触发的父组件的方法
    editDepts(node) {
      this.showDialog = true // 显示新增组件弹层
      this.node = node // 存储传递过来的node数据
      // 我们需要在这个位置 调用子组件的方法
      // 父组件 调用子组件的方法
      this.$refs.addDept.getDepartDetail(node.id) // 直接调用子组件中的方法 传入一个id
    }
  }

}
</script>
<style scoped>
.tree-card {
  padding: 30px  140px;
  font-size:14px;
}
</style>
